import Vue from 'vue'
import Router from 'vue-router'

Vue.use(Router)

/* Layout */
import Layout from '@/views/layout/Layout'

/* Router Modules */
import componentsRouter from './modules/components'
import chartsRouter from './modules/charts'
import tableRouter from './modules/table'
import nestedRouter from './modules/nested'

/** note: Submenu only appear when children.length>=1
 *  detail see  https://panjiachen.github.io/vue-element-admin-site/guide/essentials/router-and-nav.html
 **/

/**
* hidden: true                   if `hidden:true` will not show in the sidebar(default is false)
* alwaysShow: true               if set true, will always show the root menu, whatever its child routes length
*                                if not set alwaysShow, only more than one route under the children
*                                it will becomes nested mode, otherwise not show the root menu
* redirect: noredirect           if `redirect:noredirect` will no redirect in the breadcrumb
* name:'router-name'             the name is used by <keep-alive> (must set!!!)
* meta : {
    roles: ['admin','editor']     will control the page roles (you can set multiple roles)
    title: 'title'               the name show in submenu and breadcrumb (recommend set)
    icon: 'svg-name'             the icon show in the sidebar,
    noCache: true                if true ,the page will no be cached(default is false)
  }
**/
export const constantRouterMap = [
  {
    path: '/redirect',
    component: Layout,
    hidden: true,
    children: [
      {
        path: '/redirect/:path*',
        component: () => import('@/views/redirect/index')
      }
    ]
  },
  {
    path: '/login',
    component: () => import('@/views/login/index'),
    hidden: true
  },
  {
    path: '/auth-redirect',
    component: () => import('@/views/login/authredirect'),
    hidden: true
  },
  {
    path: '/404',
    component: () => import('@/views/errorPage/404'),
    hidden: true
  },
  {
    path: '/401',
    component: () => import('@/views/errorPage/401'),
    hidden: true
  },
  {
    path: '',
    component: Layout,
    redirect: 'dashboard',
    hidden: true,
    children: [
      {
        path: 'dashboard',
        component: () => import('@/views/dashboard/index'),
        name: 'Dashboard',
        meta: { title: '首页', icon: 'dashboard', noCache: true }
      }
    ]
  }
  // {
  //   path: '/documentation',
  //   component: Layout,
  //   redirect: '/documentation/index',
  //   children: [
  //     {
  //       path: 'index',
  //       component: () => import('@/views/documentation/index'),
  //       name: 'Documentation',
  //       meta: { title: 'documentation', icon: 'documentation', noCache: true }
  //     }
  //   ]
  // },
  // {
  //   path: '/guide',
  //   component: Layout,
  //   redirect: '/guide/index',
  //   children: [
  //     {
  //       path: 'index',
  //       component: () => import('@/views/guide/index'),
  //       name: 'Guide',
  //       meta: { title: 'guide', icon: 'guide', noCache: true }
  //     }
  //   ]
  // }
]

export default new Router({
  // mode: 'history', // require service support
  scrollBehavior: () => ({ y: 0 }),
  routes: constantRouterMap
})

// demo配置路由参考
export const asyncRouterMapDemo = [
  {
    path: '/permission',
    component: Layout,
    redirect: '/permission/index',
    alwaysShow: true, // will always show the root menu
    meta: {
      title: 'permission',
      icon: 'lock',
      roles: ['admin', 'editor'] // you can set roles in root nav
    },
    children: [
      {
        path: 'page',
        component: () => import('@/views/permission/page'),
        name: 'PagePermission',
        meta: {
          title: 'pagePermission',
          roles: ['admin'] // or you can only set roles in sub nav
        }
      },
      {
        path: 'directive',
        component: () => import('@/views/permission/directive'),
        name: 'DirectivePermission',
        meta: {
          title: 'directivePermission'
          // if do not set roles, means: this page does not require permission
        }
      }
    ]
  },

  {
    path: '/icon',
    component: Layout,
    children: [
      {
        path: 'index',
        component: () => import('@/views/svg-icons/index'),
        name: 'Icons',
        meta: { title: 'icons', icon: 'icon', noCache: true }
      }
    ]
  },

  /** When your routing table is too long, you can split it into small modules**/
  componentsRouter,
  chartsRouter,
  nestedRouter,
  tableRouter,

  {
    path: '/example',
    component: Layout,
    redirect: '/example/list',
    name: 'Example',
    meta: {
      title: 'example',
      icon: 'example'
    },
    children: [
      {
        path: 'create',
        component: () => import('@/views/example/create'),
        name: 'CreateArticle',
        meta: { title: 'createArticle', icon: 'edit' }
      },
      {
        path: 'edit/:id(\\d+)',
        component: () => import('@/views/example/edit'),
        name: 'EditArticle',
        meta: { title: 'editArticle', noCache: true },
        hidden: true
      },
      {
        path: 'list',
        component: () => import('@/views/example/list'),
        name: 'ArticleList',
        meta: { title: 'articleList', icon: 'list' }
      }
    ]
  },

  {
    path: '/tab',
    component: Layout,
    children: [
      {
        path: 'index',
        component: () => import('@/views/tab/index'),
        name: 'Tab',
        meta: { title: 'tab', icon: 'tab' }
      }
    ]
  },

  {
    path: '/error',
    component: Layout,
    redirect: 'noredirect',
    name: 'ErrorPages',
    meta: {
      title: 'errorPages',
      icon: '404'
    },
    children: [
      {
        path: '401',
        component: () => import('@/views/errorPage/401'),
        name: 'Page401',
        meta: { title: 'page401', noCache: true }
      },
      {
        path: '404',
        component: () => import('@/views/errorPage/404'),
        name: 'Page404',
        meta: { title: 'page404', noCache: true }
      }
    ]
  },

  {
    path: '/error-log',
    component: Layout,
    redirect: 'noredirect',
    children: [
      {
        path: 'log',
        component: () => import('@/views/errorLog/index'),
        name: 'ErrorLog',
        meta: { title: 'errorLog', icon: 'bug' }
      }
    ]
  },

  {
    path: '/excel',
    component: Layout,
    redirect: '/excel/export-excel',
    name: 'Excel',
    meta: {
      title: 'excel',
      icon: 'excel'
    },
    children: [
      {
        path: 'export-excel',
        component: () => import('@/views/excel/exportExcel'),
        name: 'ExportExcel',
        meta: { title: 'exportExcel' }
      },
      {
        path: 'export-selected-excel',
        component: () => import('@/views/excel/selectExcel'),
        name: 'SelectExcel',
        meta: { title: 'selectExcel' }
      },
      {
        path: 'upload-excel',
        component: () => import('@/views/excel/uploadExcel'),
        name: 'UploadExcel',
        meta: { title: 'uploadExcel' }
      }
    ]
  },

  {
    path: '/zip',
    component: Layout,
    redirect: '/zip/download',
    alwaysShow: true,
    meta: { title: 'zip', icon: 'zip' },
    children: [
      {
        path: 'download',
        component: () => import('@/views/zip/index'),
        name: 'ExportZip',
        meta: { title: 'exportZip' }
      }
    ]
  },

  {
    path: '/theme',
    component: Layout,
    redirect: 'noredirect',
    children: [
      {
        path: 'index',
        component: () => import('@/views/theme/index'),
        name: 'Theme',
        meta: { title: 'theme', icon: 'theme' }
      }
    ]
  },

  {
    path: '/clipboard',
    component: Layout,
    redirect: 'noredirect',
    children: [
      {
        path: 'index',
        component: () => import('@/views/clipboard/index'),
        name: 'ClipboardDemo',
        meta: { title: 'clipboardDemo', icon: 'clipboard' }
      }
    ]
  },

  {
    path: '/i18n',
    component: Layout,
    children: [
      {
        path: 'index',
        component: () => import('@/views/i18n-demo/index'),
        name: 'I18n',
        meta: { title: 'i18n', icon: 'international' }
      }
    ]
  },

  {
    path: 'external-link',
    component: Layout,
    children: [
      {
        path: 'https://github.com/PanJiaChen/vue-element-admin',
        meta: { title: 'externalLink', icon: 'link' }
      }
    ]
  },

  { path: '*', redirect: '/404', hidden: true }
]

export const asyncRouterMap = [
  // 打开注释参考demo
  // ...asyncRouterMapDemo,
  {
    path: '/income',
    component: Layout,
    redirect: '/income/general/yinshouhuizong', // 默认子路由
    name: 'income',
    meta: {
      title: '营收报表',
      icon: 'table'
    },
    children: [
      {
        path: 'general',
        component: () => import('@/pages/report/income/index'), // Parent router-view
        name: 'general',
        meta: { title: '营业概况' },
        alwaysShow: true,
        redirect: '/income/general/yinshouhuizong',
        children: [
          {
            path: 'yinshouhuizong',
            component: () => import('@/pages/report/income/general/yinshouhuizong.vue'),
            name: 'yinshouhuizong',
            meta: { title: '营收汇总报表' }
          }
        ]
      },
      {
        path: 'details',
        component: () => import('@/pages/report/income/index'), // Parent router-view
        name: 'details',
        meta: { title: '支付明细' },
        alwaysShow: true,
        redirect: '/income/details/shishoumingxi',
        children: [
          {
            path: 'shishoumingxi',
            component: () => import('@/pages/report/income/details/shishoumingxi.vue'),
            name: 'shishoumingxi',
            meta: { title: '实收明细报表' }
          },
          {
            path: 'youhuimingxi',
            component: () => import('@/pages/report/income/details/youhuimingxi.vue'),
            name: 'youhuimingxi',
            meta: { title: '优惠明细报表' }
          }
        ]
      },
      {
        path: 'third-takeout',
        component: () => import('@/pages/report/income/index'), // Parent router-view
        name: 'third-takeout',
        meta: { title: '第三方外卖' },
        alwaysShow: true,
        redirect: '/income/third-takeout/waimaihuizong',
        children: [
          {
            path: 'waimaihuizong',
            component: () => import('@/pages/report/income/third-takeout/waimaihuizong.vue'),
            name: 'waimaihuizong',
            meta: { title: '外卖汇总报表' }
          },
          {
            path: 'waimaihuizong/orderlist',
            component: () => import('@/pages/report/income/third-takeout/sub/orderlist.vue'), // router-view
            hidden: true,
            name: 'waimaihuizong/orderlist',
            meta: { title: '查看详情' }
          }
        ]
      },
      {
        path: 'analysis',
        component: () => import('@/pages/report/income/index'), // Parent router-view
        name: 'analysis',
        meta: { title: '综合分析' },
        alwaysShow: true,
        redirect: '/income/analysis/yingyunfenxi',
        children: [
          {
            path: 'waimaihuizong',
            component: () => import('@/pages/report/income/analysis/yingyunfenxi.vue'),
            name: 'yingyunfenxi',
            meta: { title: '营运分析报表' }
          }
        ]
      }
    ]
  },
  {
    path: '/order-report',
    component: Layout,
    redirect: '/order-report/stats/dingdan', // 默认子路由
    name: 'order-report',
    meta: {
      title: '订单报表',
      icon: 'table'
    },
    children: [
      {
        path: 'stats',
        component: () => import('@/pages/report/order/index'), // Parent router-view
        name: 'stats',
        meta: { title: '订单详情' },
        alwaysShow: true,
        redirect: '/order-report/stats/dingdan',
        children: [
          {
            path: 'dingdan',
            component: () => import('@/pages/report/order/details/dingdan.vue'),
            name: 'dingdan',
            meta: { title: '订单报表' }
          },
          {
            path: 'dingdan/orderlist',
            component: () => import('@/pages/report/order/details/sub/orderlist.vue'), // router-view
            hidden: true,
            name: 'dingdan/orderlist',
            meta: { title: '查看详情' }
          },
          {
            path: 'pinglun',
            component: () => import('@/pages/report/order/details/pinglun.vue'),
            name: 'pinglun',
            meta: { title: '评论报表' }
          },
          {
            path: 'pinglun/pinglunList',
            hidden: true,
            component: () => import('@/pages/report/order/details/sub/pinglunList.vue'),
            name: 'pinglunList',
            meta: { title: '评论报表' }
          }
        ]
      }

    ]
  },
  {
    path: '/article',
    component: Layout,
    redirect: '/article/caipinxiaoshou/pinpaidanpin', // 默认子路由
    name: 'article',
    meta: {
      title: '菜品报表',
      icon: 'table'
    },
    children: [
      {
        path: 'caipinxiaoshou',
        component: () => import('@/pages/report/article/index'), // Parent router-view
        name: 'caipinxiaoshou',
        meta: { title: '菜品销售统计' },
        alwaysShow: true,
        redirect: '/article/caipinxiaoshou/pinpaicaipin',
        children: [
          {
            path: 'pinpaicaipin',
            component: () => import('@/pages/report/article/caipinxiaoshou/pinpaicaipin.vue'),
            name: 'pinpaicaipin',
            meta: { title: '品牌菜品销售' }
          },
          {
            path: 'dianpucaipin',
            component: () => import('@/pages/report/article/caipinxiaoshou/dianpucaipin.vue'),
            name: 'dianpucaipin',
            meta: { title: '店铺菜品销售' }
          }
        ]
      },
      {
        path: 'zengcai',
        component: () => import('@/pages/report/article/index'), // Parent router-view
        name: 'zengcai',
        meta: { title: '赠送统计' },
        alwaysShow: true,
        redirect: '/article/zengcai/zengcai-1',
        children: [
          {
            path: 'zengcai-1',
            component: () => import('@/pages/report/article/zengcai/zengcai.vue'),
            name: 'zengcai-1',
            meta: { title: '赠菜报表' }
          }
        ]
      },
      {
        path: 'tuicai',
        component: () => import('@/pages/report/article/index'), // Parent router-view
        name: 'tuicai',
        meta: { title: '退菜统计' },
        alwaysShow: true,
        redirect: '/article/tuicai/tuicai-1',
        children: [
          {
            path: 'tuicai-1',
            component: () => import('@/pages/report/article/tuicai/tuicai.vue'),
            name: 'tuicai-1',
            meta: { title: '退菜报表' }
          }
        ]
      }
    ]
  },
  {
    path: '/sales',
    component: Layout,
    redirect: '/sales/stats/huiyuanxinxi', // 默认子路由
    name: 'sales',
    meta: {
      title: '营销报表',
      icon: 'table'
    },
    children: [
      {
        path: 'discount',
        component: () => import('@/pages/report/sales/index'), // Parent router-view
        name: 'discount',
        meta: { title: '优惠统计' },
        alwaysShow: true,
        redirect: '/sales/discount/youhuiquan',
        children: [
          {
            path: 'youhuiquan',
            component: () => import('@/pages/report/sales/discount/youhuiquan.vue'),
            name: 'youhuiquan',
            meta: { title: '优惠券报表' }
          },
          {
            path: 'youhuiquan/list',
            component: () => import('@/pages/report/sales/discount/sub/list.vue'), // router-view
            hidden: true,
            name: 'list',
            meta: { title: '查看详情' }
          },
          {
            path: 'hongbao',
            component: () => import('@/pages/report/sales/discount/hongbao.vue'),
            name: 'hongbao',
            meta: { title: '红包报表' }
          }
        ]
      },
      {
        path: 'promotion',
        component: () => import('@/pages/report/sales/index'), // Parent router-view
        name: 'promotion',
        meta: { title: '营销活动' },
        alwaysShow: true,
        redirect: '/sales/promotion/fufeihuiyuan',
        children: [
          {
            path: 'fufeihuiyuan',
            component: () => import('@/pages/report/sales/promotion/fufeihuiyuan.vue'),
            name: 'fufeihuiyuan',
            meta: { title: '付费会员报表' }
          }

        ]
      }

    ]
  },
  {
    path: '/member',
    component: Layout,
    redirect: '/member/tongji/huiyuanxinxi', // 默认子路由
    name: 'member',
    meta: {
      title: '会员报表',
      icon: 'table'
    },
    children: [
      {
        path: 'tongji',
        component: () => import('@/pages/report/member/index'), // Parent router-view
        name: 'tongji',
        meta: { title: '会员统计' },
        alwaysShow: true,
        redirect: '/member/tongji/huiyuanxinxi',
        children: [
          {
            path: 'huiyuanxinxi',
            component: () => import('@/pages/report/member/tongji/huiyuanxinxi.vue'),
            name: 'huiyuanxinxi',
            meta: { title: '会员信息表' }
          },
          {
            path: 'huiyuanxinxi/orderList',
            hidden: true,
            component: () => import('@/pages/report/member/sub/orderList.vue'),
            name: 'huiyuanxinxi/orderList',
            meta: { title: '会员订单记录' }
          }
        ]
      },
      {
        path: 'chuzhi',
        component: () => import('@/pages/report/member/index'), // Parent router-view
        name: 'chuzhi',
        meta: { title: '会员储值' },
        alwaysShow: true,
        redirect: '/member/chuzhi/huiyuanchuzhi',
        children: [
          {
            path: 'huiyuanchuzhi',
            component: () => import('@/pages/report/member/chuzhi/huiyuanchuzhi.vue'),
            name: 'huiyuanchuzhi',
            meta: { title: '会员储值报表' }
          },
          {
            path: 'huiyuanchuzhi/chongzhiList',
            component: () => import('@/pages/report/member/sub/chongzhiList.vue'),
            hidden: true,
            name: 'huiyuanchuzhi/chongzhiList',
            meta: { title: '店铺充值记录' }
          },
          {
            path: 'huiyuanyuer',
            component: () => import('@/pages/report/member/chuzhi/huiyuanyuer.vue'),
            name: 'huiyuanyuer',
            meta: { title: '会员余额报表' }
          }
        ]
      }

    ]
  }
]
